CLAIMS 



1 1 . (Previously Presented) A processing system for performing addition and 

2 subtraction within limits upon a shared value comprising: 

3 means for performing a first uninterruptible operation upon the shared value 

4 stored in an affected reservation location, the first uninterruptible operation using an 

5 operand; 

6 means for comparing a resulting value of the first uninterruptible operation stored 

7 in the affected reservation location to an upper value and a lower value to determine if the 

8 resulting value is within a range defined by the upper value and the lower value that can 

9 be changed; 

10 means for performing a second uninterruptible operation to restore the affected 

1 1 reservation location if the resulting value of the first uninterruptible operation is not 

12 within the range defined by the upper value and the lower value; 

13 means for reporting a failure if the resulting value of the first uninterruptible 

14 operation is not within the range defined by the upper value and the lower value; 

1 5 means for performing a third uninterruptible operation to update an actual value 

16 location if the resulting value of the first uninterruptible operation is within the range 

17 defined by the upper value and the lower value; 

1 8 means for performing a fourth uninterruptible operation to update an unaffected 

19 reservation location if the resulting value of the first uninterruptible operation is within 

20 the range defined by the upper value and the lower value; and 

21 means for reporting a success if the resulting value of the first uninterruptible 

22 operation is within the range defined by the upper value and the lower value. 



PA1671US 



2 



Response to 1 1/21/2006 Commu 



1 2. (Previously presented) The processing system of claim 1 wherein the first, 

2 second, third, and fourth uninterruptible operations are LOCK XADD operations. 

1 3. (Previously presented) A processing system for performing addition and 

2 subtraction within limits upon a shared value comprising: 

3 means for receiving an operand; 

4 means for performing a first uninterruptible operation upon the shared 

5 value stored in an affected reservation location, the first uninterruptible operation 

6 using the operand; 

7 means for comparing a resulting value of the first uninterruptible operation 

8 stored in the affected reservation location to an upper value and a lower value to 

9 determine if the resulting value is within a range defined by the upper value and 

1 0 the lower value that can be changed; 

1 1 means for performing a second uninterruptible operation to restore the 

12 affected reservation location if the resulting value of the first uninterruptible 

1 3 operation is not within the range defined by the upper value and the lower value; 

14 means for reporting a failure if the resulting value of the first 

1 5 uninterruptible operation is not within the range defined by the upper value and 

16 the lower value; 

1 7 means for performing a third uninterruptible operation to update an actual 

1 8 value location if the resulting value of the first uninterruptible operation is within 

1 9 the range defined by the upper value and the lower value; 
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20 means for performing a fourth uninterruptible operation to update an 

21 unaffected reservation location if the resulting value of the first uninterruptible 

22 operation is within the range defined by the upper value and the lower value; and 

23 means for reporting a success if the resulting value of the first 

24 uninterruptible operation is within the range defined by the upper value and the 

25 lower value. 

1 4. (Previously presented) The processing system of claim 3 wherein the first, 

2 second, third, and fourth uninterruptible operations are LOCK XADD operations. 

1 5. (Currently Amended) A method for performing addition and subtraction within 

2 limits upon a shared value comprising the steps of: 

3 performing a first uninterruptible operation upon the shared value stored in 

4 an affected reservation location, the first uninterruptible operation using an 

5 operand; 

6 comparing a resulting value of the first uninterruptible operation stored in 

7 the affected reservation location to an upper value and a lower value to determine 

8 if the resulting value is within a range defined by the upper value and the lower 

9 value that can be changed; 

10 if the resulting value is not within the range defined by the upper value 

1 1 and the lower value: 

12 performing a second uninterruptible operation to restore the 

13 affected reservation location, and 

14 reporting a failure; and 

15 if the resulting value is within the range defined by the upper value and the 

16 J lower valuefi 

1 7 performing a third uninterruptible operation to update an actual 

1 8 value location^ 
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performing a fourth uninterruptible operation to update an 
unaffected reservation location, and 
reporting a success. 

6. (Previously Presented) The method of claim 5 wherein the first, second, third, 
and fourth uninterruptible operations are LOCK XADD operations. 

7. (Previously Presented) A computer readable medium containing computer 
readable code comprising: 

a code segment for performing a first uninterruptible operation upon the 
shared value stored in an affected reservation location, the first uninterruptible 
operation using an operand; 

a code segment for comparing a resulting value of the first uninterruptible 
operation stored in the affected reservation location to an upper value and a lower 
value to determine if the resulting value is within a range defined by the upper 
value and the lower value that can be changed; 

a code segment for performing a second uninterruptible operation to 
restore the affected reservation location; 

a code segment for reporting a failure if the resulting value is not within 
the range defined by the upper value and the lower value; 

a code segment for performing a third uninterruptible operation to update 
an actual value location if the resulting value is within the range defined by the 
upper value and the lower value; 
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17 a code segment for performing a fourth uninterruptible operation to update 

18 an unaffected reservation location if the resulting value is within the range defined 

19 by the upper value and the lower value; and 

20 a code segment for reporting a success if the resulting value is within the 

21 range defined by the upper value and the lower value. 

1 8. (Previously Presented) A processing system for performing addition and 

2 subtraction within limits upon a shared value, the processing system comprising: 

3 a processor configured for 

4 performing a first uninterruptible operation upon the shared value 

5 stored in an affected reservation location, the first uninterruptible 

6 operation using an operand; 

7 comparing a resulting value of the first uninterruptible operation 

8 stored in the affected reservation location to an upper value and a lower 

9 value to determine if the resulting value is within a range defined by the 

10 upper value and the lower value that can be changed; 

11 performing a second uninterruptible operation to restore the 

12 affected reservation location if the resulting value of the first 

13 uninterruptible operation is not within the range defined by the upper 

14 value and the lower value; 

1 5 reporting a failure if the resulting value of the first uninterruptible 

16 operation is not within the range defined by the upper value and the lower 

17 value; 
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1 8 performing a third uninterruptible operation to update an actual 

19 value location if the resulting value of the first uninterruptible operation is 

20 within the range defined by the upper value and the lower value; 

21 performing a fourth uninterruptible operation to update an 

22 unaffected reservation location if the resulting value of the first 

23 uninterruptible operation is within the range defined by the upper value 

24 and the lower value; and 

25 reporting a success if the resulting value of the first uninterruptible 

26 operation is within the range defined by the upper value and the lower 

27 value. 

1 9. (Previously presented) A method of performing subtraction or addition within 

2 limits, the method comprising: 

3 receiving an operand from a processing thread; 

4 performing a first uninterruptible operation upon an affected reservation 

5 location, the affected reservation location including a first instance of a shared 

6 first value, the first uninterruptible operation being configured to generate a 

7 second value by subtracting the operand from or adding the operand to the first 

8 instance of the shared first value; 

9 comparing the generated second value in the affected reservation location 

10 to one or more limit values stored in one or more limit locations; 

1 1 performing a second uninterruptible operation to restore the shared first 

12 value in the affected reservation location if the second value is not within any of 

13 the one or more limit values; 
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14 reporting a failure if the second value is not within any of the one or more 

15 limit values; 

16 performing a third uninterruptible operation to update a second instance of 

17 the shared first value stored in an actual value location if the second value is 

1 8 within the one or more limit values, the actual value location being a memory 

1 9 location shared by a plurality of processing threads; and 

20 performing a fourth uninterruptible operation to update a third instance of 

21 the shared first value stored in an unaffected reservation location if the second 

22 value is within the one or more limit values. 

1 10. (Previously presented) The method of claim 9, further including reporting a 

2 success if the second value is within the one or more limit values. 

1 11. (Previously presented) The method of claim 9, wherein the one or more 

2 limit values consist of an upper limit value and a lower limit value. 

1 12. (Previously presented) The method of claim 9, wherein the first 

2 uninterruptible operation is configured to generate the second value by adding the 

3 operand to the first instance of the shared first value. 

1 13. (Previously presented) The method of claim 9, wherein the first 

2 uninterruptible operation is configured to generate the second value by subtracting the 

3 operand from the first instance of the shared first value. 
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1 14. (Previously presented) The method of claim 9, wherein the operand has an 

2 absolute value greater than one. 

1 15. (Previously presented) The method of claim 9, wherein performing the 

2 second uninterruptible operation includes using a negative of the operand. 

1 16. (Previously presented) The method of claim 9, further including choosing 

2 the first affected reservation location on which to perform the first uninterruptible 

3 operation, responsive to whether the method is being used to perform a subtraction or 

4 addition. 

1 17. (Previously presented) The system of claim 1, further including means 

2 configured for choosing the first affected reservation location on which to perform the 

3 first uninterruptible operation, responsive to whether the system is being used to perform 

4 a subtraction or addition. 
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